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At least one client application (510) cre- 
ates a message to be transmitted to a receiver 
(240). The client application transmits the 
message to an encoder which receives the mes- 
sage and other messages from other client ap- 
plications. The encoder transforms the com- 
posite messages into packets and multiplexes 
them into a bitstream to be encoded with a 
video programming signal. The multiplexing 
is performed according to priorities assigned 
to the at least one client application and the 
other applications. The encoder transmits the 
bitstream to a video encoder to transmit the 
bitstream with the programming signal to be 
received by a decoder. The decoder can then 
decode the information from the video signal 
and transmit the information to at least one 
decoder client application. The client applica- 
tions may include a status application which 
transmits a status information (e.g. time ref- 
erences) at regular intervals; a program appli- 
cation which transmits descriptive information 
of the video programming synchronized with 
the video signal (e.g. program markers and/or 
program text, such as closed-captions and/or 
subtitles); and a non-program application. 
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VIDEO INDEXING PROTOCOL 

PACKgRQUND QF THE INVENTION 

1. Field of the invention 

The present invention relates to video transmission/reception 
systems. More specifically, the present invention relates to a protocol 
and apparatus for transmitting information in conjunction with a video 
signal 

2. Background Information 

With the proliferation of personal computer systems and the 
decline in costs of high-capacity computer technology in general, the 
technologies of television transmission and computer applications are 
starting to merge. Solutions have been slow in coming, however. 

For certain applications in television program transmission, it is 
desirable to transmit information in addition to the audio/video portion of 
the signal. For example, closed-captioned programming is now being 
used extensively to serve the needs of the hearing-impaired. In fact, 
recent requirement for television receivers include the requirement that all 
receivers provide this capability to display, in text, the audio portion of the 
transmitted program. 

For news programming, other needs have arisen. For example, 
for 24-hour a day news programming, real-time stock quotes and sports 
scores are now being displayed as part of the video portion of the signal 
on services such as Headline News (a trademark of Turner 
Broadcasting, Inc.). Although this serves the needs of the viewer, 
providing such real-time information, this solution not only distracts the 
viewer of the video screen, but also unnecessarily consumes screen 
space, and does not allow the viewer to view the information which is of 
interest to him. For example, to view the price of a particular stock, the 
viewer has to wait until the ticker cycles back to display that information. 
The same deficiency is true for sports scores. Other viewers, such as 
those requiring real-time weather information needs are also not met. 
Thus, an improved means for obtaining such information is required. 
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Prior art solutions such as closed-captioning use the vertical 
blanking interval (VBI) for encoding text for the audio portion of the 
programming. It typically uses line 21 of the vertical synchronization 
portion of the video signal Thus, although it does not interfere with the 
transmission of the video signal, it has lacked the capability to be used in 
any other way, rather than real-time display the user, such as indexing, 
full-text capture, and/or other text processing operations commonly 
performed in modern personal computer word processing application 
programs. 

Another shortcoming of closed-captioning is that although it uses a 
portion of the VBI for transmission (line 21), is does not make efficient 
use of the bandwidth of that portion of the non-displayed video signal. It 
is estimated that a single line of the VBI can be used for uncompressed 
data transmission at approximately 14.4 kilobytes/second. Thus, real- 
time closed captioning of the audio program of a televised broadcast 
does not take full advantage of the bandwidth of the signal. It also is a 
unichannel system, wherein only the closed captioning information is 
transmitted, rather than taking advantage of the full-bandwidth of the 
signal. 

Prior art information which has been transmitted in conjunction 
with television programming sometimes only transmits limited information 
about the programming. For example, in consumer satellite television 
reception systems, usually only text information describing the title of the 
program, and at most, the time elapsed or time remaining in the program 
has been transmitted with the programming. More detailed information, 
such as references to outside sources related to the programming, or 
other information, which is synchronized with the programming has not 
been transmitted in conjunction with the signal. 

Thus, the prior art of for transmitting information with television 
programming suffers from several shortcomings. 
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SUMMARY OF THE INVENTION 

A computer-implemented method and apparatus for transmitting 
information with a video signal. At least one client application creates a 
message to be transmitted to a receiver The client application transmits 
the message to a data encoder and the encoder receives the message 
and other messages from other client applications. The encoder 
transforms the message and the other messages into packets and 
multiplexes them into a bitstream to be encoded with a video 
programming signal. The multiplexing is performed according to priorities 
assigned to the at least one client application and the other client 
applications. Then, the encoder transmits the bitstream to a video 
encoder to transmit the bitstream with the video programming signal in 
order to be received by a decoder. The decoder can then decode the 
information from the video signal and transmit the information to at least 
one decoder client application. The client applications may include: a 
status application which transmits a status information (e.g. time 
references) at regular intervals; a program application which transmits 
descriptive information of the video programming synchronized with the 
video signal (e.g. program markers and/or program text, such as closed- 
captions and/or subtitles); and a non-program application. The status 
application may have a highest priority, the program application has a 
next highest of priority, and the non-programming signal has a lowest 
priority. In this manner, useful, descriptive and other program or non- 
program-related information may be transmitted along with the video 
signal, and displayed and processed according to user requirements. 
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BRIEF DESCRIPTION OF THE DRAWINGS 

The present invention is illustrated by way of example and not 
limitation in the figures of the accompanying in which like references 
indicate like elements and in which: 

Figure 1 shows a system in which an encoder can be 
implemented. 

Figure 2 shows a system in which an decoder can be 
implemented. 

Figure 3 shows a block diagram of devices in a networking system 
in which embodiments of present invention may be implemented. 

Figure 4 shows the software architecture of an encoder. 

Figure 5 shows the software architecture of a decoder. 

Figure 6 shows a specific implementation of the software in a 
decoder. 

Figure 7a shows the processes performed by the encoder process. 

Figure 7b shows the relationship of the messages, packets and 
frames in the encoder in relation to the ISO/OSI model in one 
embodiment of the present invention. 

Figure 8 shows the format of a message used for the application 
program interface (API) between the encoder/decoder and client 
applications. 

Figure 9 shows the format of a packet. 

Figure 10 shows the format of a frame. 

Figure 1 1 shows the format of a status composite packet. 

Figure 12 shows the format of a program marker packet. 

Figure 13 shows the format of a non-program stock quote packet. 

Figure 14 shows an example packet bitstream. 

Figures 15a-15c show the operation of the encoder's main 
processes. 

Figures 16a-16c show the operation of the decoder's main 
processes. 

Figure 17 shows an example user interface window which main be 
used by a client application program of a decoder, or an authoring client 
application program at the transmitter. 
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Figure 18 shows an example of a user display displaying the 
audio/video program, the program information and non-program 
information which may be displayed by separate client applications. 
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DEIA1L&D d^sqripjion 

The present invention is a method and apparatus for transmitting 
information in conjunction with a video signal. The system to be 
described here includes the Video Indexing Protocol (VIP). The 
techniques to be described here can be used to transmit any information 
in conjunction with a video signal, although, specific information has been 
described for illustration purposes. Although the present invention will be 
described with reference to certain specific embodiments, including 
specific data packets, types of communication media, networking 
systems, transmission apparatus, etc., it can be appreciated by one 
skilled in the art that these are for illustrative purposes only and are not to 
be construed as limiting the present invention. Other departures, 
modifications, and other changes may be made, by one skilled in the art, 
without departing from the teaching of the present invention. 

The methods and apparatus used in implemented embodiments of 
the present invention comprise an encoder portion and a decoder portion, 
examples of which are shown in Figures 1 and 2. The encoder or "head 
end" of the video transmission system may have a structure as illustrated 
in Figure 1. The system includes a master encoder 100 which may 
receive encoded messages from a plurality of computer systems 110-114 
which communicate with encoder 100 via networking medium 150. 
Network 150 may be any number of prior art networks, including local 
area networks (LAN's), such as ethernet, token-ring, FDDI, or other 
networking media as are commercially available. The encoders 110-114 
will convert their respective information into messages to be processed 
by encoder 100, and software, operative within encoder 100, will then 
packetize and prioritize these messages as packets which are then 
transmitted to VBI inserter 130. 

VBI inserter 130 may be any number of VBI inserters as are 
commercially available, such as the model number TDS-3 brand VBI 
inserter available from norpak Corporation of Ottawa, Ontario, Canada. 
Note that for the remainder of this application, VBI inserters into an 
audio/video program signal (NTSC) will be discussed, however, this is for 
illustration purposes only, and other audio/video encodings for other 
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formats (e.g. PAL, SECAM), and other broadcasting methods (e.g. digital 
video). This information may then be transmitted via satellite uplink 140, 
along with the audio/video program content. The signal may also be 
broadcast, cablecast or transmitted in other ways, according to 
implementation, and this invention is not limited to satellite uplinks or 
downlinks. Each of the encoders 110-114 may have a different encoding 
function, such as closed-captioned or foreign-language subtitles, stock 
quotes, news text, sports scores, or weather, with serialized bitstreams 
feeding those encoders. In addition to this information, status information 
for the transmission such as timecodes (e.g. timecodes, such as SMPTE 
timecodes, or time reference markers such as GMT), station ID, and 
channel map. This may include program content information. This may 
include generic information, such as scene or story markers, and for an 
application such as a news transmission, the program content information 
may include text of the news stories. Any other information, real-time or 
not, may be included within the information which is encoded. 

The structure of the decoder is shown in Figure 2. Figure 2 
essentially performs the reverse of the apparatus shown in Figure 1 . A 
satellite downlink 240 may receive the encoded audio/video program 
which is then decoded by a VBI decoder 230 into the separate program 
and encoded data portions. Then, a master decoder or gateway 
computer system receives the encoded data, and the different channels 
of information can be made available to a plurality of client systems 210- 
214 over a networking medium, for example. For example, each of the 
computer systems 210-214 may each be interested in a separate portion 
of the bitstream. Thus, those clients may only need to examine a portion, 
or channel (e.g. program information, stock, sports scores, weather), of 
the incoming bitstream, according to user requirements. The details of 
this will be discussed more below. 

Although separate systems are shown in Figures 1 and 2, it can be 
appreciated that such is for illustration purposes only, and that in a 
multitasking environment, a single one of the systems (e.g. 100, 200), 
may be used for encoding wherein any or all of the separate encoders 
(e.g. 110-1 14, 210-214) can be implemented as separate processes 
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resident in a single computer. The techniques have equal application to 
multitasking, multicomputing, or networking environments. 

Referring to Figure 3, a system 310 upon which one embodiment 
of a computer system (e.g. encoder 100 or decoder 200) of the present 
invention as implemented is shown. 31 0 comprises a bus or other 
communication means 301 for communicating information, and a 
processing means 302 coupled with bus 301 for processing information. 
System 310 further comprises a random access memory (RAM) or other 
volatile storage device 304 (referred to as main memory), coupled to bus 
301 for storing information and instructions to be executed by processor 
302. Main memory 304 also may be used for storing temporary variables 
or other intermediate information during execution of instructions by 
processor 1 52. System 31 0 also comprises a read only memory (ROM) 
and/or other static storage device 306 coupled to bus 301 for storing 
static information and instructions for processor 302, and a data storage 
device 307 such as a magnetic disk or optical disk and its corresponding 
disk drive. Data storage device 307 is coupled to bus 301 for storing 
information and instructions. 

System 31 0 may further be coupled to a display device 321 , such 
as a cathode ray tube (CRT) or liquid crystal display (LCD) coupled to 
bus 301 for displaying information to a computer user. An alphanumeric 
input device 322, including alphanumeric and other keys, may also be 
coupled to bus 301 for communicating information and command 
selections to processor 302. An additional user input device is cursor 
control 323, such as a mouse, a trackball, stylus, or cursor direction keys, 
coupled to bus 301 for communicating direction information and 
command selections to processor 302, and for controlling cursor 
movement on display 321 . 

In implemented embodiments, other devices which may be 
coupled to bus 301 include a serial interface 324 and/or a communication 
device 325 either of which comprise means for communicating with other 
devices. This communication device may also include a means for 
communicating with other nodes in a network. In implemented 
embodiments, this may include an Ethernet standard interface coupled to 
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a CSMA/CD backplane for communicating information with other 
computers (e.g. encoders 110-11 4, or decoders 21 0-214). Note, also, 
that any or all of the components of system 310 and associated hardware 
may be used in various embodiments, however, it can be appreciated 
that any configuration of the system that includes a processor 302 may 
be used for various purposes according to the particular implementation. 

In one embodiment, system 310 is one of the IBM AT-compatible 
type personal computers such as the Gateway 2000 brand personal 
computer manufactured by Gateway Computer Systems. Processor 302 
may be one of the Pentium® brand microprocessors available from Intel 
Corporation of Santa Clara, California (Pentium and Intel are trademarks 
of Intel Corporation). 

Note that the following discussion of various embodiments 
discussed herein will refer specifically to a series of routines which are 
generated in a high-level programming language (e.g.. the C or C++ 
language) and compiled, linked, and then run as object code in system 
31 0 during run-time. It can be appreciated by one skilled in the art. 
however, that the following methods and apparatus may be implemented 
in special purpose hardware devices, such as discrete logic devices, 
large scale integrated circuits (LSI's), application-specific integrated 
circuits (ASIC's), or other specialized hardware. The description here has 
equal application to apparatus having similar function. 

Figure 4 shows an example software architecture of the processes 
which include the encoder. A plurality of processes either resident within 
a single device (e.g. 100 of Figure 1) or each of a plurality of client 
encoders (e.g. 1 10-114) may include a plurality of client application 
programs 401-403 which communicate via messages to the main video 
indexing protocol (VIP) encoder 41 0. VIP encoder 41 0 implements the 
transport, network and data link layers of the ISO/OSI networking model 
via separate portions 410a, 410b and 410c of the encoder. Client 
applications operate at the application layer. The VIP encoder 410 
provides the necessary communication between the application layer 
(client application programming interface or API) and the VBI inserter 130 
which resides at the physical layer. Specific client applications may 
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include stock quotes may be provided. VIP encoder 41 0 may further 
accept as inputs timecode, GMT time references, or other time reference 
via an internal or house clock at the encoder via a special-purpose client 
application program which is used for transmitting status information to 
decoders, such as 200 shown in Figure 2. 

Figure 5 illustrates a more detailed view of the software processes 
operative within a decoder (e.g. 200 of Figure 2). The decoder will 
include a VIP decoder process 500 which communicates with the VBI 
decoder apparatus 230 after decoding of the input data from the 
audio/video programming received from downlink 240. The VIP decoder 
500, like the VIP encoder 400, communicates with a plurality of registered 
client applications 510-513 via client bitstreams, which each may be 
comprise a separate portion(s) of the multiplexed data stream, according 
to the client applications' requirements. 

In implemented embodiments of the present invention, 256 
separate prioritized channels are capable of being transmitted between a 
VIP encoder/decoder and client processes. The VIP decoder may extract 
a status channel for status information which is received from the encoder 
at periodic intervals, which is used for controlling/timing the decoder and 
the other client application programs. This may be handled by a status 
client 610 as illustrated in Figure 6, which communicates with a control 
module 601 , which is responsible for controlling the decoding process 
500 itself. In addition, status information may be provided to the program 
application 620 which is responsible, for example, for receiving real-time 
descriptive information about the program. Such descriptive information 
may include program/story/segment markers, full-text of the program 
and/or other descriptive information about the program which is 
synchronized with transmission. The details of program descriptive 
information will be discussed in more detail below. Status information 
may also be input to any an/or all other client application programs 631- 
633, according to implementation. The remaining non-program channels 
of information, which have a lower priority than status and program 
information, may include stock quotes, sports scores, weather, or other 
information which is transmitted (and received) as bandwidth permits. 
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The specifics of the function of the encoder will be described in 
more detail with reference to Figure 7a. A plurality of VIP application 
programs 701-703 communicate with the VIP encoder process 400 via 
Vt_Messages, the details of which are illustrated in Figure 8. Each of the 
applications is prioritized. For example, a status application has priority 0 
(the highest), and program information has priority 1 (second highest) and 
other, non-program channels, have priority 3. When Vt_Messages 71 1- 
713 are received by the encoder, transmission of packets such as 722 to 
the data link layer is performed on a prioritized round-robin basis. In 
other words, highest priority Vt_Message channels are serviced until 
exhausted, and channels having the same priority are serviced in round- 
robin fashion. These are then converted by the datalink layer 724 into 
frames 725 for transmission to VBI inserter 130. The details of the 
reception of messages and transformation of messages into packets, and 
packets into frames is shown in Figure 7b. 

As Vt_Messages 750 are serviced in the input buffer they are 
transformed by the network layer 755 in the encoder into Vt_Packets 760- 
762. illustrated in more detail in Figure 9. Packets are identified by 
message number and their sequence in the message. Once packetized 
by the network layer 755, these messages are then sent as packets 760- 
762 to the datalink layer 724 in the encoder. The datalink layer 724 then 
creates a Vt_Frame 770-772 for each of the packets 760-762, 
respectively. These frames are then transmitted to the physical layer for 
encoding into the vertical blanking interval by the VBI inserter 130. 
Vt_Frames are discussed and described in more detail with reference to 
Figure 1 0, below. Vt_Frames are serialized and then encoded by VBI 
inserter 1 30 for transmission in any number of prior art manners. 

The format of a Vt_Message is illustrated as 800 in Figure 8. Each 
message contains a first field, nMessageProtocol 801 , a byte, which is 
used for identifying the information transmitted (e.g. status, program, 

stocks, sports, weather, etc ). In this way, the messages can be 

prioritized. The next field nVersion 802, is a byte identifying the version 
of this protocol which is being used. The field flsHint 803 is indicates that 
the message is being provided before an event. This allows equipment in 



WO 96/13124 PCT/US95/14594 



-12- 

the receiver to "pre-roir as necessary. flsUPdate field 804 indicates 
updated information (e.g. outline updates or revised news stories). The 
fReserved 805 field is currently not used: The field nDataSize 806 is a 
double-word used for specifying the number of bytes of the data 
contained in the bData field 809. The field nOpcode 807 is used for 
specifying the specific operation to be performed upon the data contained 
in the message. Applications communicate with the encoder by opening 
a communication channel and send messages to the encoder. In this 
example, opcodes may be integer values specifying any of the following: 
GetStationID, SetStationID, GetTime, SetTime, GetChannelMap, 
ChannelOpen, ChannelClose, ChannelGet Priority, ChannelSetPriority, 
and SendMessage. The next field fReserved2 808 is currently not used, 
and bData field 809 is variable length, according to the length of the data 
specified in field 806. Responsive to any of the operations specified by 
the opcodes, the encoder may sent result codes to the client applications, 
such as error or completion codes. These result codes may include: 
ChannelAlreadyOpen; ChannelNotOpen; ChannelBusy; 
NotChannelOwner; ProtocolMismatch; CommError; NoMoreChannels; 
NoMessage; or BadData. 

As discussed above, the scheduler in the encoder services 
applications according to the priority of the channel, and then in round- 
robin fashion, for creating and transmitting packets . The structure of a 
packet is illustrated in Figure 9. 900 of figure 9 shows the format of the 
packets which are created and then transmitted in the serialized 
multiplexed bitstream in Vt_Frames to the VBI inserter 130. The 
nPacketProtocol 901 field is a byte-length field which identifies the packet 
as one supported by this protocol or other values for other protocols 
which may be transmitted in future embodiments. The nVersion 902 is 
used for specifying the version of the encoder which is creating and 
transmitting the packets. The nChanID field 903 is a byte specifying, as 
an integer value, the channel number of the packet in the serialized 
bitstream. The nMessagelD field 904 specifies the message number on 
the particular channel, from which the packet was obtained. This is used 
for sending the message in the proper order at the decoder. The 
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nPacketlD field 905 is the number of the packet in the particular 
message. Again, this is used for constructing the message. The 
fMorePackets field 906 is a boolean used for specifying whether there are 
any more packets for the message. If not, then the decoder can detect 
that it has all the packets for the message, and can transmit the message 
to the proper client(s). The fReserved 907 field is currently unused and 
the nDataSize field 908 specifies the size of the bData field 909 in bytes. 
The bData field 909 is a variable-length field which is used for containing 
the data. It has the length specified in nDataSize field 908. 

Figure 10 illustrates the format of a Vt_Frame 1000, which is 
transmitted to the VBI inserter 130. VIP packets are serialized into byte 
stream frames to be sent to the VBI inserter 1 30. Frames consist of fields 
for indicating the start and end of the frame, and data is pre-stuffed so 
that it doesn't have any occurrences of the start or end characters. As 
illustrated in Figure 10, the start frame field STX 1001 thus precedes the 
Vt_Packet information 1002, a single Vt_Packet, such as 900. The 
bitstream 1002 is followed by a CRC check field 1003, and an end of 
frame character ETX 1 004 to indicate the end of the frame. 

Figure 1 1 illustrates Vt_Status_Composite packet, which is 
generated by the encoder and is sent to all decoders at regular (e.g. 5 
second) intervals. The Vt_Status_Composite packet allows 
synchronization of decoder applications to the encoder. The packet 1 1 00 
includes a xStationID field 1 101 , which identifies the station performing 
the transmission (e.g. "CNN Headline News"). The packet includes the 
xTime field 1 102, which is a time reference synchronized to the house 
clock of the transmitter. In implemented embodiments which transmit 
status packets at 5 second intervals, the time is GMT, however, in other 
embodiments, SMPTE time codes may be used wherein status packets 
are sent every video frame (30 fps). Other time references may be used, 
according to implementation. Finally, a channel map 1 103 is included in 
the packet, which includes the highest channel transmitted, and a 
variable size portion containing identifying information for each channel 
(e.g. VIP protocols). 



WO 96/13124 



PCT/US95/14594 



-14- 

Figure 12 illustrates a program packet, Vt_Program_Marker 1200, 
which is used for real-time description of audio/video program data. 
Other program packets may also be transmitted. These include: 

1 . events - which encode a momentary type of action, such as 
a camera switch, zoom, transition or other editing 
command. This type may include: 

a. a type (camera switch, zoom, transition, etc....). 

b. a length; 

c. body (data for the event); 

2. VIFs (video image format) - indicates that a plurality of 
frames should be captured by a digitizing board in the 
receiver. This may be stored and used for reference (e.g. a 
weather map); 

3. captions - full-text of all spoken material; 

4. sidebars - referential data. These may include, but not be 
limited to: 

a. URL (Universal Resource Locaters) - for locating 
information on the WWW (World-Wide Web) which 
may be related to the program; 

b. OLE Pointer - Microsoft's Object Linking and 
Embedding protocol for locating data on the client 
machine which is program-related. 

Vt_Program_Marker 1200 is used for real-time identification of the 
program which is being transmitted. It is transmitted every 5 seconds, or 
when the status of the program (e.g. nLevel or nltem) changes. Other 
types of program packets are sent on an as-needed basis according to 
the application's requirements. Program markers can be sent 
synchronized with the video program, or some time period in relation to 
the program, according to implementation. For example, program 
markers of a certain type may precede the event by some relationship in 
order to allow activation and synchronization of device(s) in the receiver. 
The nType field 1201 precedes program packets to identify the type of 
the packet (e.g. marker, event, caption, sidebar, etc..) There are also 
different types of markers which may be encoded into field 1201 which 
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specify: program; story; segment; section; segment; or commercial. 
These are used to indicate the beginning/ending of a program chunk. 

Vt_Program_Marker 1200 uses nLevel field 1202 to identify the 
outline level which this marker describes. This will be used to display, 
access, or reassemble the program. The nLevel field 1202 may be used 
to display identifying information in outline form on a client computer, 
nltem field 1203 identifies the particular item at the identified outline level. 
The nBytes field 1204 identifies the length of the strings which have been 
packed into field szText 1205. For example, if the nLevel field 1202 
contained a 2, then there would be three strings (for three levels) packed 
into szText field 1205 (the level is 0 based, wherein 0 is the first level). 
For a news program, the information may include, for example: Program - 
"CNN Headline News; Segment - "Dollars & Sense"; and Story - "Intel 
Stock Soars." For a televised play, this may include, for example: Play - 
"Henry IV"; Act - "Act Three"; and Scene - "Scene Five- Cade Conspires 
with Dirk." Other types of program packets, may also be transmitted, and 
are within the spirit and scope of the present invention. 

Other types of non-program packets may also be transmitted. 
These include: stock quotations; sports scores; and weather information. 
These are transmitted in priority after both status and program 
information on a bandwidth-available, real-time basis. An example of a 
stock quotation packet is shown in Figure 13 as Vt_Quote_Tick packet 
1 300, which is sent every time a stock quote is read off a feed to the 
encoder. This packet includes a signature word field wSig 1301 for 
identifying the quotation; a stock change exchange identifier xExchange 
field 1302; a ticker symbol field szSymbol 1303; a number of transactions 
field 1304; and a transactions array 1305, containing transaction 
information for the number of transactions specified in field 1 304. 

A typical VIP bitstream is illustrated as 1400 in Figure 14. Packets 
are illustrated as 1401-1412, wherein status packets are sent on a regular 
basis (e.g. every 5 seconds) such as 1401 and 141 1 , in order to keep the 
receiver(s) synchronized with the transmitter. Program marker packets 
such as 1402 and 1412 are similarly sent, as well as when program 
content changes, in order to indicate the change. Non-status, non- 
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program packets 1403-1410 are sent in the remaining time, in round- 
robin fashion, as bandwidth permits. 

The encoders' three main processes for the different layers are 
shown in Figures 1 5a-1 5c. Figure 1 5a illustrates the sequence of steps 
performed by at the Transport/API layer of the ISO/OSI model. Note that 
processes are implemented using object-oriented techniques, and thus, 
source code references object(s) and accompanying processes which 
service those object(s). Thus, the precise sequence of execution of the 
three subprocesses shows in Figures 15a-15c may not necessarily be 
precisely sequential. At any rate, the Transport/API layer receives a 
message from a client application, and determines whether it is a timer 
event (e.g. thus requiring transmission of a status message) at step 1504. 
If it is, then at step 1506, a Vt_Status_Composite message is sent. If not, 
it is determined whether the message is of the ChannelOpen/Close type. 
If so, then the corresponding action is performed at step 1510, and a 
status message is sent indicating the change in channel. If the message 
was not of the open/close type, as detected at step 1508, then the 
process proceeds to step 1512, which determines whether a message is 
pending on the channel. If so, then a responsive message (e.g. 
ChannelBusy) is returned to the application at step 1514, and the 
application can take some corrective action. If not, then the message is 
queued on the current channel at step 1516, and sent to the network 
layer for packetizing. The process is thus complete at step 1 51 8. 

Network layer processing in the encoder is illustrated in Figure 
15b. If no more messages are pending in the message, as detected at 
step 1 520, then the process remains idle at step 1522. If, however, 
message(s) are awaiting processing, then the highest priority channel 
with message(s) waiting is determined at step 1524. The next channel 
with the selected priority is then selected for message processing at step 
1526, in round-robin fashion. This is to allow equivalent processing of 
messages for applications having the same channel priority. A Vt_Packet 
is then constructed from a portion of the Vt_Message from the selected 
client at step 1528. The maximum packet length for each packet is used 
until the message is exhausted, wherein the last packet for a message is 
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variable length, according to the portion of the message which remains. 
Once this has been performed, the Vt_Packet is then sent to the Datalink 
layer, at step 1530, and the process continues processing messages at 
step 1520. 

Figure 1 5c illustrates the datalink layer processing which is 
performed in the encoder. The steps 1532-1548 are performed on each 
Vt_Packet received from the network layer in order to create a VtJFrame. 
First, at step 1532, a CRC (cyclic redundancy check) computation is 
performed upon the packet, at step 1532. Then, a start of frame 
character STX is added to the frame at step 1 534. 

The processing of the packet then commences, wherein a check at 
step 1536 determines whether there are any more characters to be 
processed in the packet. If so, then the process proceeds to step 1538. 
Loop 1536-1 542 packs the packet, preceding any occurrences of the 
STX, ETX or DLE (data-link escape) characters by DLE. If the character 
is none of these three, as detected at step 1538, then it is placed into the 
frame at step 1 542. If it is one of the three characters, then it is preceded 
by DLE, and placed into the frame at step 1542. Step 1536 then repeats 
until no more characters are in the packet. 

Once processing of the packet is complete, as detected at step 
1 536, then the process proceeds to step 1 544, wherein the computed 
CRC is placed into the frame to allow parity checking. An ETX character 
is then added to signify the end of the frame at step 1 546, and the 
Vt_Frame can then be transmitted to an output serial port of the encoder 
in order to be merged with the audio/video program (e.g. by VBI inserter 
1 30). Encoding is thus complete. 

The decoder's operation at the three network layers is shown in 
Figures 16a-16c. Datalink processing in the decoder is illustrated in 
Figure 16a. Datalink processing is performed at step 1632 wherein a 
block is received from a serial port (e.g. from VBI decoder 230), and 
copied to the ring buffer. At 1633, it is determined whether a Vt^Packet is 
currently being examined. If not, then the STX character is located at 
step 1634 to locate the beginning of the message. Upon completion of 
step 1634 or upon determination that a Vt_Packet is already being 
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examined at step 1633, it is determined at step 1636 whether any more 
characters are are in the ring buffer to process. If not, the block reception 
continues at step 1632. If there are more characters tin the ring buffer, as 
detected at step 1636, then the process proceeds to step 1638 wherein it 
is determined whether the character is an ETX character. If the character 
is not an ETX, then the character is copied to the VT_Packet buffer at 
step 1640. This loop continues until no more characters are to be 
processed in the ring buffer, or the ETX character is located. Once the 
ETX character is detected at step 1 638, then the end of the frame has 
been reached, and the processing of the packet can take place. At step 
1642, a CRC of the packet is performed. If it fails, the data has been 
corrupted, then the Vt_Packet buffer is discarded at step 1 644. If the 
CRC check passes, then the Vt_Packet may then be sent to the network 
layer at step 1646. Then, the process continues to wait, in loop 1632- 
1636, to locate the STX character and determine if any more characters 
are received. 

Network layer processing is shown in Figure 16b. A Vt_Packet is 
received at step 1614. Steps 1616-1620 check the Vt_Packet_Size, to 
determine if any bits were lost, Vt_Packet_MessagelD, to determine if 
this refers to a valid message, and Vt_Packet_PacketlD, to determine if 
this refers to a valid packet in the message. If any of these checks fail, 
then the VtJWessage under construction is discarded at step 1622, and 
the process proceeds to an idle state 1624, until a subsequent Vt_Packet 
is received. Once the packet is determined as valid, as detected at steps 
1 61 6-1 620, the Vt_Packet is then added to the message under 
construction at step 1626. Then, if there are no more packets in the 
message, as detected at step 1628, a build Vt_Message is sent to the 
transport layer in order to communicate with any client(s). If there are 
more Vt_Packets in the message, as detected at step 1628, then the 
process continues at step 1614. 

The operation of the transport layer is illustrated in Figure 16c. 
Message(s) are received at the transport layer from the network layer at 
step 1602. First, it is determined whether it is a Vt_Status message at 
step 1 604. If so, then it is determined whether any of the channels are 
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being closed by ihe status message. If so, then the local status cache of 
the channel is rebuilt, rebuilding the channel map, at step 1608, and a 
ChannelClosed message is sent to all local client applications at step 
161 0. The process then proceeds to step 1 612, which is also performed 
if the message was not a status message. At step 1612, the Vt_Message 
is then transmitted to the application(s) listening to the message's 
channel. 

An example of a program information window, as may be 
displayed on the display of a suitably programmed microcomputer (e.g. 
310 of Figure 3) or other apparatus having similar function executing a 
program information client application is shown as 1700 of Figure 17. 
Such a program information window may be displayed using any number 
of commercially-available graphical user interfaces (GUI) such as the 
Windows brand GUI available from Microsoft Corporation of Redmond, 
Washington. As illustrated, the program information window may display 
program information in outline form, as derived from a packet such as the 
program marker packet 1200, as described with reference to Figure 12, 
above. In this news application window 1700, the program title is 
displayed as the window title, and segment titles are show as 1710, 1720, 
1 730 and 1 740. Story headings, such as 1 71 1 -1 71 8, as discussed 
above, are referenced in order of appearance under the headline. Using 
this type of display, using any of the pull-down menu options 1750, other 
options may be accessed, such as real-time stock quotes, sports scores, 
or other non-program information. Selection of any of the headlines 
171 1-1718 may allow display of text of the story, closed captioned 
information, and/or other program-related information, such as events, 
captions, sidebars, or other useful information. 

Another example of a display during a user-session at the decoder 
is shown in Figure 18. Window 1810 presents the televised audio/video 
program, which may be executed under control of a first task in a 
multitasking environment, and may be fed by any number of sources (e.g. 
satellite, broadcast, cable, or digital transmission). A second task, a 
client of the VIP decoder (e.g. 500 of Figure 5), may display program- 
related information in a window such as 1820, such as headlines for news 
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stories. Any other transmitted program information may be accessed 
using this window under control of the program client. Finally, non- 
program information, such as real-time stock quotations, may be 
displayed in window 1 830 under control of a third task, also a client of the 
decoder. In this way, program and non-program information may be 
displayed to the user, depending upon which information he considers of 
interest, and which client application(s) are activated. 

Using the above-described methods, apparatus, packets and 
protocols, client application programs can communicate with a main 
decoder process (e.g. 500 of Figure 5) and obtain useful, multiplexed 
serialized data which is received along with transmitted audio/video 
information, and extract certain useful information according to 
requirements. The post-processing, including the display of user- 
interfaces, control of additional device(s) (e.g. video digitizers or video 
recorders), or other responsive actions in the clients as s result of the 
reception of such information may be performed according to 
implementation. The transmission or reception of such information does 
not interfere with the audio/video programming transmitted concurrently 
therewith, and also, takes advantage of the unused bandwidth provided 
by such transmissions. Thus, implemented embodiments of the present 
invention present advantages neither recognized nor realized by the prior 
art. 

Thus, method and apparatus for transmission of information along 
with audio/video programming has been described. Note that though the 
foregoing has particular utility in these systems, and although it has been 
described with reference to certain specific embodiments in the figures 
and the text, that one may practice the present invention without utilizing 
all of these specific details. Thus, the figures and the text are to be 
viewed an illustrative sense only, and not limit the present invention. The 
present invention is only to be limited by the appended claims which 
follow. 
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ClAIMS 

What is claimed is: 



1 . A computer-implemented method for transmitting information with 
a video signal, comprising the following steps: 

a. at least one client application creating a message to be 
transmitted to a receiver; 

b. said client application transmitting said message to a data 
encoder; 

c. said encoder receiving said message and other messages 
from other client applications; 

d. said data encoder transforming said message and said 
other messages into packets and multiplexing said packets 
into a bitstream to be encoded with a video programming 
signal, said multiplexing being performed according to 
priorities assigned to said at least one client application and 
said other client applications; and 

e. said encoder transmitting said bitstream to a video encoder 
to transmit said bitstream with said video programming 
signal in order to be received by a decoder. 

2. The method of claim 1 wherein said at least one client application 
includes a status application which transmits said messages 
containing status information at regular intervals. 

3. The method of claim 1 wherein said at least one client application 
includes a program application which transmits descriptive 
information of said video programming synchronized with said 
video signal. 

4. The method of claim 1 wherein said at least one client application 
includes a non-program application. 
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5. The method of claim 1 wherein said at least one client application 
includes a status application which transmits said messages 
containing status information at regular intervals, a program 
application which transmits descriptive information of said video 
programming synchronized with said video signal, and a non- 
program application, wherein said status application has a highest 
of said priority, said program application has a next highest of said 
priority, and said non-programming signal has a lowest of said 
priority. 
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